define(['jquery', 'bootstrap', 'backend', 'table', 'form', 'jstree'], function ($, undefined, Backend, Table, Form, JsTree) {

	var Controller = {
		index: function () {

			// 初始化表格参数配置
			Table.api.init({
				extend: {
					index_url: 'data/region.json',
				}
			});

			var table = $("#table");

			table.bootstrapTable({
				url: $.fn.bootstrapTable.defaults.extend.index_url,
				columns: [
					[
						//该列为复选框字段,如果后台的返回state值将会默认选中
						{ field: 'id', title: '序号', operate: false },
						{ field: 'region', title: '区域名称', align: 'left', searchList: ['华南区域', '华北区域','华东区域'], operate: false },
						{ field: 'base_area', title:'占地面积', operate: false},
						{ field: 'building_area', title: '建筑面积', operate: false },
						{ field: 'manage_area', title: '管理面积', operate: false },
						{ field: 'charge_area', title: '收费面积', operate: false },
						{ field: 'forest_area', title: '绿化面积', operate: false },
						{ field: 'club_area', title: '会所面积' , operate: false},
						{ field: 'company_count', title: '公司数', operate: false },
						{ field: 'project_count', title: '项目数', operate: false },
						{ field: 'building_count', title: '楼栋数', operate: false },
						{ field: 'carport_count', title: '车位数', operate: false },
						{ field: 'house_count', title: '总户数', operate: false },
						{ field: 'unsold_count', title: '未售户数' , operate: false},
						{ field: 'unreceived_count', title: '已售未收户数' , operate: false},
						{ field: 'received_count', title: '已售已收户数', operate: false },
					],
				],
				//禁用默认搜索
				search: false,
				//启用普通表单搜索
				commonSearch: false,
				//可以控制是否默认显示搜索单表,false则隐藏,默认为false
				searchFormVisible: false,
				detailView: false,
				showExport: false
			});

//在表格内容渲染完成后回调的事件
			table.on('post-body.bs.table', function (e, settings, json, xhr) {

			});

// 为表格绑定事件
			Table.api.bindevent(table);

//指定搜索条件
			$(document).on("click", ".btn-singlesearch", function () {
				var options = table.bootstrapTable('getOptions');
				options.pageNumber = 1;
				options.queryParams = function (params) {
					return {
						search: params.search,
						sort: params.sort,
						order: params.order,
						filter: JSON.stringify({ admin_id: 1 }),
						op: JSON.stringify({ admin_id: '=' }),
						offset: params.offset,
						limit: params.limit,
					};
				};
				table.bootstrapTable('refresh', {});
				Toastr.info("当前执行的是自定义搜索");
				return false;
			});

//获取选中项
			$(document).on("click", ".btn-selected", function () {
				Layer.alert(JSON.stringify(table.bootstrapTable('getSelections')));
			});

//启动和暂停按钮
			$(document).on("click", ".btn-start,.btn-pause", function () {
				//在table外不可以使用添加.btn-change的方法
				//只能自己调用Table.api.multi实现
				Table.api.multi("changestatus", 0, table, this);
			});

		},
		add: function () {
			Controller.api.bindevent();
		},
		edit: function () {
			Controller.api.bindevent();
		},
		api: {
			bindevent: function () {
				Form.api.bindevent($("form[role=form]"));
			},
			formatter: {//渲染的方法
				url: function (value, row, index) {
					return '<div class="input-group input-group-sm" style="width:250px;"><input type="text" class="form-control input-sm" value="' + value + '"><span class="input-group-btn input-group-sm"><a href="' + value + '" target="_blank" class="btn btn-default btn-sm"><i class="fa fa-link"></i></a></span></div>';
				},
				ip: function (value, row, index) {
					return '<a class="btn btn-xs btn-ip bg-success"><i class="fa fa-map-marker"></i> ' + value + '</a>';
				},
				browser: function (value, row, index) {
					//这里我们直接使用row的数据
					return '<a class="btn btn-xs btn-browser">' + row.useragent.split(" ")[0] + '</a>';
				},
				custom: function (value, row, index) {
					//添加上btn-change可以自定义请求的URL进行数据处理
					return '<a class="btn btn-xs btn-danger btn-change" data-url="example/bootstraptable/change" data-id="' + row.id + '">' + __('Locked') + '</a>';
				},
				operate: function (value, row, index) {
					//返回字符串加上Table.api.formatter.operate的结果
					//默认需要按需显示排序/编辑/删除按钮,则需要在Table.api.formatter.operate将table传入
					//传入了table以后如果edit_url为空则不显示编辑按钮,如果del_url为空则不显显删除按钮
					return '<a class="btn btn-info btn-xs btn-detail"><i class="fa fa-list"></i> ' + __('Detail') + '</a> '
						+ Table.api.formatter.operate(value, row, index, $("#table"));
				},
			},
			events: {//绑定事件的方法
				ip: {
					//格式为：方法名+空格+DOM元素
					'click .btn-ip': function (e, value, row, index) {
						e.stopPropagation();
						console.log();
						var container = $("#table").data("bootstrap.table").$container;
						var options = $("#table").bootstrapTable('getOptions');
						//这里我们手动将数据填充到表单然后提交
						$("form.form-commonsearch [name='ip']", container).val(value);
						$("form.form-commonsearch", container).trigger('submit');
						Toastr.info("执行了自定义搜索操作");
					}
				},
				browser: {
					'click .btn-browser': function (e, value, row, index) {
						e.stopPropagation();
						Layer.alert("该行数据为: <code>" + JSON.stringify(row) + "</code>");
					}
				},
				operate: $.extend({
					'click .btn-detail': function (e, value, row, index) {
						e.stopPropagation();
						Backend.api.open('example/bootstraptable/detail/ids/' + row['id'], __('Detail'));
					}
				}, Table.api.events.operate)
			}
		}
	};
	return Controller;
});
